### CSCI 210: Computer Architecture Lecture 26: Control Path

Stephen Checkoway Slides from Cynthia Taylor

# CS History: Apple Lisa



- First mass-market PC that used a graphical user interface
- Released in 1983
- Cost \$9,995 (equivalent to \$29,400 in 2022)
- Used the Motorola 68000 CPU, the first 32-bit CPU
- Shipped with 1 MB of RAM

### **Control Path**

 Our data path is complicated, and we don't use each element every time

• How do we know which elements to use?

### Recall: PLAs



• Derived from truth table using sum of products

• Allow us to encode arbitrary functions

• Used to derive control signals in the data path

#### Datapath With Control



#### The Main Control Unit

#### Control signals derived from instruction opcode



# **Fetching Instructions**

- Read instruction from Instruction Memory
- Updating PC value to address of next (sequential) instruction
- PC is updated every clock cycle, so it does not need an explicit write control signal just a clock signal
- Read from memory each time, so we don't need an explicit control signal





- Read two values from the Register File
- Register numbers are contained in the instruction (rs and rt)

# Producing control signals

After reading opcode

- Produce most control signals
- Includes the ALUOp control signal—which goes to the ALU control unit—and the ALUSrc control signal which selects the ALU's second operand



# For load/store, our ALU operation will be

A. Add

B. And

C. Set less than

D. Subtract

E. None of the above



lw \$t0, 4(\$t1)

# ALU Control Unit

- Combinational logic (the main control unit) derives 2-bit ALUOp signal from opcode
- ALU Control Unit takes ALUOp and instruction funct field as inputs and derives a 4-bit ALU control signal

| opcode | ALUOp | Operation        | ALU function     |
|--------|-------|------------------|------------------|
| lw     | 00    | load word        | add              |
| SW     | 00    | store word       | add              |
| beq    | 01    | branch equal     | subtract         |
| R-type | 10    | arithmetic/logic | depends on funct |





# **ALU Control signal**

- ALU used for
  - Load/Store: op = add
  - Branch: op = subtract
  - R-type: op depends on funct field



| ALU control        | Function         | Ainvert | Binvert/CarryIn0 | Operation |
|--------------------|------------------|---------|------------------|-----------|
| 0000               | AND              | 0       | 0                | 00        |
| 0001               | OR               | 0       | 0                | 01        |
| <mark>0</mark> 010 | add              | 0       | 0                | 10        |
| <mark>0</mark> 110 | subtract         | 0       | 1                | 10        |
| <mark>0</mark> 111 | set-on-less-than | 0       | 1                | 11        |
| <b>1</b> 100       | NOR              | 1       | 1                | 00        |

# **ALU Control**



# Takes as input 2-bit ALUop (derived from opcode) and 6-bit funct field; outputs 4 bits

| Instruction      | ALUOp         | funct  | ALU function     | Ainvert | Binvert | ALU<br>operation |
|------------------|---------------|--------|------------------|---------|---------|------------------|
| load word        | 00 (add)      | XXXXXX | add              | 0       | 0       | 10 (add)         |
| store word       | 00 (add)      | XXXXXX | add              | 0       | 0       | 10 (add)         |
| branch equal     | 01 (subtract) | XXXXXX | subtract         | 0       | 1       | 10 (add)         |
| add              | 10 (r-type)   | 100000 | add              | 0       | 0       | 10 (add)         |
| subtract         |               | 100010 | subtract         | 0       | 1       | 10 (add)         |
| AND              |               | 100100 | AND              | 0       | 0       | 00 (and)         |
| OR               |               | 100101 | OR               | 0       | 0       | 01 (or)          |
| NOR              |               | 100111 | NOR              | 1       | 1       | 00 (and)         |
| set-on-less-than |               | 101010 | set-on-less-than | 0       | 1       | 11 (less)        |

#### **Executing R Format Operations**

• R format operations (add, sub, slt, and, or)

|         | 31 | 25 | 20 | 15 | 10    | 5 0   |
|---------|----|----|----|----|-------|-------|
| R-type: | ор | rs | rt | rd | shamt | funct |

- perform operation (specified by funct) on values in rs and rt

- store the result back into the Register File (into location rd)



Note that Register File is not written every cycle (e.g., **sw**), so we need an explicit write control signal for the Register File



#### **R-Type Instruction**



#### **Executing Load and Store Operations**

- compute memory address by adding base register to 16-bit signed-extended offset field
- store value written to the Data Memory
- load value read from the Data Memory, written to the Register File





#### Which wire, if always set to 1 would break lw?



Load/

Store



25:21

20:16

31:26

ALUOp = 00 (add) ALUOp = 01 (subtract) ALUOp = 10 (R-type)





#### **Executing Branch Operations**

- Branch operations involve
  - compare the operands read from the Register File during decode for equality (zero ALU output)
  - compute the branch target address by adding the updated PC to



#### **Branch-on-Equal Instruction**



31:26 25:21 20:16 15:0

### **Control Truth Table**

|         |          | R-format | lw     | SW     | beq    |
|---------|----------|----------|--------|--------|--------|
| Opcode  |          | 000000   | 100011 | 101011 | 000100 |
|         | RegDst   | 1        | 0      | X      | X      |
|         | ALUSrc   | 0        | 1      | 1      | 0      |
| Outputs | MemtoReg | 0        | 1      | X      | X      |
|         | RegWrite | 1        | 1      | 0      | 0      |
|         | MemRead  | 0        | 1      | 0      | 0      |
|         | MemWrite | 0        | 0      | 1      | 0      |
|         | Branch   | 0        | 0      | 0      | 1      |
|         | ALUOp1   | 1        | 0      | 0      | 0      |
|         | ALUOp0   | 0        | 0      | 0      | 1      |

ALUOp = 00 (add)

ALUOp = 01 (subtract)

ALUOp = 10 (R-type, use funct to determine ALUCtrl signals)

# Implementing Jumps



- Jump uses word address
- Update PC with concatenation of
  - Top 4 bits of PC + 4
  - 26-bit jump address
  - 00



| Select | Best Answer                                  |
|--------|----------------------------------------------|
| А      | Yes – we need both new control and datapath. |
| В      | Yes – we need just datapath.                 |
| С      | No – but we should for better performance.   |
| D      | No – just changing control signals is fine.  |
| Е      | Single cycle can't do jump register.         |

#### Datapath With Jumps Added





